table of contents
SYSINFO(2) | Руководство программиста Linux | SYSINFO(2) |
ИМЯ¶
sysinfo - возвращает общесистемную статистику
ОБЗОР¶
#include <sys/sysinfo.h>
int sysinfo(struct sysinfo *info);
ОПИСАНИЕ¶
В ядрах Linux версий, более ранних, чем 2.3.16, sysinfo() возвращал следующую структуру:
struct sysinfo {
long uptime; /* Количество секунд, прошедшее
с загрузки системы */
unsigned long loads[3]; /* средняя 1, 5 и 15-минутная загруженность
системы */
unsigned long totalram; /* Общий объём доступной оперативной памяти */
unsigned long freeram; /* Объём свободной памяти */
unsigned long sharedram; /* Объём общей памяти */
unsigned long bufferram; /* Объём памяти, использованной под буферы */
unsigned long totalswap; /* Общий объём области подкачки */
unsigned long freeswap; /* Объём свободного пространства в области
подкачки */
unsigned short procs; /* Текущее количество процессов */
char _f[22]; /* Дополнение структуры до 64 байтов */ };
все размеры считаются в байтах.
Начиная с ядра версии 2.3.23 (i386), 2.3.48 (остальные архитектуры), структура стала следующей:
struct sysinfo {
long uptime; /* Количество секунд, прошедшее с загрузки
системы */
unsigned long loads[3]; /* средняя 1, и 15-минутная загруженность
системы */
unsigned long totalram; /* Общий объём доступной оперативной памяти */
unsigned long freeram; /* Объём свободной памяти */
unsigned long sharedram; /* Объём общей памяти */
unsigned long bufferram; /* Объём памяти, использованной под буферы */
unsigned long totalswap; /* Общий объём области подкачки */
unsigned long freeswap; /* Объём свободного пространства в области
подкачки */
unsigned short procs; /* Текущее количество процессов */
unsigned long totalhigh; /* Общий объём дальней (high) памяти */
unsigned long freehigh; /* Объём свободной дальней памяти */
unsigned int mem_unit; /* Размер элемента памяти в байтах */
char _f[20-2*sizeof(long)-sizeof(int)]; /* Дополнение до 64 байт */ };
для получения размеров в байтах их надо умножить на mem_unit.
sysinfo() предоставляет простой способ получения общесистемной статистики. Это более переносимый способ по сравнению с чтением /dev/kmem.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.
ОШИБКИ¶
- EFAULT
- Недопустимый указатель на struct sysinfo
СООТВЕТСТВИЕ СТАНДАРТАМ¶
Данная функция есть только в Linux и не должна использоваться в программах, которые задуманы как переносимые.
Системный вызов sysinfo() есть в ядре Linux начиная с версии 0.98.pl6. В Linux libc функция sysinfo() появилась в версии 5.3.5, а в glibc начиная с 1.90.
СМОТРИТЕ ТАКЖЕ¶
2012-05-05 | Linux |